home *** CD-ROM | disk | FTP | other *** search
/ SGI Freeware 2001 May / SGI Freeware 2001 May - Disc 1.iso / dist / fw_qt.idb / usr / freeware / include / qlist.h.z / qlist.h
C/C++ Source or Header  |  2001-04-12  |  6KB  |  140 lines

  1. /****************************************************************************
  2. ** $Id: qt/src/tools/qlist.h   2.3.0   edited 2001-01-26 $
  3. **
  4. ** Definition of QList template/macro class
  5. **
  6. ** Created : 920701
  7. **
  8. ** Copyright (C) 1992-2000 Trolltech AS.  All rights reserved.
  9. **
  10. ** This file is part of the tools module of the Qt GUI Toolkit.
  11. **
  12. ** This file may be distributed under the terms of the Q Public License
  13. ** as defined by Trolltech AS of Norway and appearing in the file
  14. ** LICENSE.QPL included in the packaging of this file.
  15. **
  16. ** This file may be distributed and/or modified under the terms of the
  17. ** GNU General Public License version 2 as published by the Free Software
  18. ** Foundation and appearing in the file LICENSE.GPL included in the
  19. ** packaging of this file.
  20. **
  21. ** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition
  22. ** licenses may use this file in accordance with the Qt Commercial License
  23. ** Agreement provided with the Software.
  24. **
  25. ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
  26. ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  27. **
  28. ** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
  29. **   information about Qt Commercial License Agreements.
  30. ** See http://www.trolltech.com/qpl/ for QPL licensing information.
  31. ** See http://www.trolltech.com/gpl/ for GPL licensing information.
  32. **
  33. ** Contact info@trolltech.com if any conditions of this licensing are
  34. ** not clear to you.
  35. **
  36. **********************************************************************/
  37.  
  38. #ifndef QLIST_H
  39. #define QLIST_H
  40.  
  41. #ifndef QT_H
  42. #include "qglist.h"
  43. #endif // QT_H
  44.  
  45.  
  46. template<class type> class Q_EXPORT QList : public QGList
  47. {
  48. public:
  49.     QList()                {}
  50.     QList( const QList<type> &l ) : QGList(l) {}
  51.    ~QList()                { clear(); }
  52.     QList<type> &operator=(const QList<type> &l)
  53.             { return (QList<type>&)QGList::operator=(l); }
  54.     bool operator==( const QList<type> &list ) const
  55.     { return QGList::operator==( list ); }
  56.     uint  count()   const        { return QGList::count(); }
  57.     bool  isEmpty() const        { return QGList::count() == 0; }
  58.     bool  insert( uint i, const type *d){ return QGList::insertAt(i,(QCollection::Item)d); }
  59.     void  inSort( const type *d )    { QGList::inSort((QCollection::Item)d); }
  60.     void  prepend( const type *d )    { QGList::insertAt(0,(QCollection::Item)d); }
  61.     void  append( const type *d )    { QGList::append((QCollection::Item)d); }
  62.     bool  remove( uint i )        { return QGList::removeAt(i); }
  63.     bool  remove()            { return QGList::remove((QCollection::Item)0); }
  64.     bool  remove( const type *d )    { return QGList::remove((QCollection::Item)d); }
  65.     bool  removeRef( const type *d )    { return QGList::removeRef((QCollection::Item)d); }
  66.     void  removeNode( QLNode *n )    { QGList::removeNode(n); }
  67.     bool  removeFirst()            { return QGList::removeFirst(); }
  68.     bool  removeLast()            { return QGList::removeLast(); }
  69.     type *take( uint i )        { return (type *)QGList::takeAt(i); }
  70.     type *take()            { return (type *)QGList::take(); }
  71.     type *takeNode( QLNode *n )        { return (type *)QGList::takeNode(n); }
  72.     void  clear()            { QGList::clear(); }
  73.     void  sort()            { QGList::sort(); }
  74.     int      find( const type *d )        { return QGList::find((QCollection::Item)d); }
  75.     int      findNext( const type *d )    { return QGList::find((QCollection::Item)d,FALSE); }
  76.     int      findRef( const type *d )    { return QGList::findRef((QCollection::Item)d); }
  77.     int      findNextRef( const type *d ){ return QGList::findRef((QCollection::Item)d,FALSE);}
  78.     uint  contains( const type *d ) const { return QGList::contains((QCollection::Item)d); }
  79.     uint  containsRef( const type *d ) const
  80.                     { return QGList::containsRef((QCollection::Item)d); }
  81.     type *at( uint i )            { return (type *)QGList::at(i); }
  82.     int      at() const            { return QGList::at(); }
  83.     type *current()  const        { return (type *)QGList::get(); }
  84.     QLNode *currentNode()  const    { return QGList::currentNode(); }
  85.     type *getFirst() const        { return (type *)QGList::cfirst(); }
  86.     type *getLast()  const        { return (type *)QGList::clast(); }
  87.     type *first()            { return (type *)QGList::first(); }
  88.     type *last()            { return (type *)QGList::last(); }
  89.     type *next()            { return (type *)QGList::next(); }
  90.     type *prev()            { return (type *)QGList::prev(); }
  91.     void  toVector( QGVector *vec )const{ QGList::toVector(vec); }
  92. private:
  93.     void  deleteItem( QCollection::Item d );
  94. };
  95.  
  96. #if defined(Q_DELETING_VOID_UNDEFINED)
  97. template<> inline void QList<void>::deleteItem( QCollection::Item )
  98. {
  99. }
  100. #endif
  101.  
  102. template<class type> inline void QList<type>::deleteItem( QCollection::Item d )
  103. {
  104.     if ( del_item ) delete (type *)d;
  105. }
  106.  
  107.  
  108. template<class type> class Q_EXPORT QListIterator : public QGListIterator
  109. {
  110. public:
  111.     QListIterator(const QList<type> &l) :QGListIterator((QGList &)l) {}
  112.    ~QListIterator()          {}
  113.     uint  count()   const     { return list->count(); }
  114.     bool  isEmpty() const     { return list->count() == 0; }
  115.     bool  atFirst() const     { return QGListIterator::atFirst(); }
  116.     bool  atLast()  const     { return QGListIterator::atLast(); }
  117.     type *toFirst()          { return (type *)QGListIterator::toFirst(); }
  118.     type *toLast()          { return (type *)QGListIterator::toLast(); }
  119.     operator type *() const   { return (type *)QGListIterator::get(); }
  120.     type *operator*()         { return (type *)QGListIterator::get(); }
  121.  
  122.     // No good, since QList<char> (ie. QStrList fails...
  123.     //
  124.     // MSVC++ gives warning
  125.     // Sunpro C++ 4.1 gives error
  126.     //    type *operator->()        { return (type *)QGListIterator::get(); }
  127.  
  128.     type *current()   const   { return (type *)QGListIterator::get(); }
  129.     type *operator()()          { return (type *)QGListIterator::operator()();}
  130.     type *operator++()          { return (type *)QGListIterator::operator++(); }
  131.     type *operator+=(uint j)  { return (type *)QGListIterator::operator+=(j);}
  132.     type *operator--()          { return (type *)QGListIterator::operator--(); }
  133.     type *operator-=(uint j)  { return (type *)QGListIterator::operator-=(j);}
  134.     QListIterator<type>& operator=(const QListIterator<type>&it)
  135.                   { QGListIterator::operator=(it); return *this; }
  136. };
  137.  
  138.  
  139. #endif // QLIST_H
  140.